home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Aminet 37
/
Aminet 37 (2000)(Schatztruhe)[!][Jun 2000].iso
/
Aminet
/
dev
/
lang
/
sofa.lha
/
sofa
/
smalleiffel
/
lib_se
/
manifest_string_pool.e
< prev
next >
Wrap
Text File
|
2000-03-25
|
10KB
|
342 lines
-- This file is part of SmallEiffel The GNU Eiffel Compiler.
-- Copyright (C) 1994-98 LORIA - UHP - CRIN - INRIA - FRANCE
-- Dominique COLNET and Suzanne COLLIN - colnet@loria.fr
-- http://SmallEiffel.loria.fr
-- SmallEiffel is free software; you can redistribute it and/or modify it
-- under the terms of the GNU General Public License as published by the Free
-- Software Foundation; either version 2, or (at your option) any later
-- version. SmallEiffel is distributed in the hope that it will be useful,but
-- WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
-- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
-- for more details. You should have received a copy of the GNU General
-- Public License along with SmallEiffel; see the file COPYING. If not,
-- write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-- Boston, MA 02111-1307, USA.
--
class MANIFEST_STRING_POOL
--
-- Unique global object in charge of MANIFEST_STRING used.
--
inherit GLOBALS;
feature {MANIFEST_STRING}
register(ms: MANIFEST_STRING): STRING is
-- To register a runnable one.
-- Choose the appropriate mangling.
require
ms /= Void;
not small_eiffel.is_ready
local
x: INTEGER;
do
header.copy("ms");
x := ms.start_position.base_class.id;
x.append_in(header);
header.extend('_');
x := ms.to_string.hash_code;
x.append_in(header);
from
until
not mangling_dictionary.has(header)
loop
header.extend('a');
end;
Result := header.twin;
mangling_dictionary.put(ms,Result);
end;
feature {SMALL_EIFFEL}
falling_down is
do
if mangling_dictionary.count > 0 then
type_string.set_at_run_time;
end;
end;
c_define1(string_at_run_time: BOOLEAN) is
do
if not string_at_run_time then
cpp.put_string(
"typedef struct S7 T7;%N%
%struct S7{T9 _storage;T2 _count;T2 _capacity;};%N");
end;
end;
c_define2(string_at_run_time: BOOLEAN) is
require
cpp.on_c
local
i, j, function_count, mdc: INTEGER;
ms: MANIFEST_STRING;
do
mdc := mangling_dictionary.count;
echo.print_count("Manifest String",mdc);
if mdc > 0 then
from -- For *.h :
i := 1;
until
i > mdc
loop
ms := mangling_dictionary.item(i);
header.copy(fz_t7_star);
header.append(ms.mangling);
cpp.put_extern1(header);
i := i + 1;
end;
end;
define_se_ms(string_at_run_time);
if mdc > 0 then
from -- For *.c :
i := 1;
function_count := 1;
until
function_count > 1 and then i > mdc
loop
header.copy(fz_void);
header.extend(' ');
header.append(fz_se_msi);
function_count.append_in(header);
header.append(fz_c_void_args);
from
body.clear;
j := nb_ms_per_function;
until
j = 0 or else i > mdc
loop
ms := mangling_dictionary.item(i);
body.append(ms.mangling);
body.append("=se_ms(");
ms.count.append_in(body);
body.extend(',');
string_to_c_code(ms.to_string,body);
body.append(fz_14);
j := j - 1;
i := i + 1;
end;
function_count := function_count + 1;
if i <= mdc then
body.append(fz_se_msi);
function_count.append_in(body);
body.append(fz_c_no_args_procedure);
end;
cpp.put_c_function(header,body);
if function_count \\ 5 = 0 then
cpp.padding_here;
end;
end;
cpp.padding_here;
end;
ensure
cpp.on_c
end;
feature {C_PRETTY_PRINTER}
string_to_c_code(s: STRING; c_code: STRING) is
local
i: INTEGER;
do
c_code.extend('%"');
from
i := 1;
until
i > s.count
loop
character_to_c_code(s.item(i),c_code);
i := i + 1;
end;
c_code.extend('%"');
end;
character_to_c_code(c: CHARACTER; c_code: STRING) is
do
if c = '%N' then
c_code.extend('\');
c_code.extend('n');
elseif c = '\' then
c_code.extend('\');
c_code.extend('\');
elseif c = '%"' then
c_code.extend('\');
c_code.extend('%"');
elseif c = '%'' then
c_code.extend('\');
c_code.extend('%'');
elseif c.code < 32 or else 122 < c.code then
c_code.extend('\');
c.code.to_octal.append_in(c_code);
c_code.extend('%"');
c_code.extend('%"');
else
c_code.extend(c);
end;
end;
c_call_initialize is
require
cpp.on_c
do
if mangling_dictionary.count > 0 then
cpp.put_string(fz_se_msi);
cpp.put_character('1');
cpp.put_string(fz_c_no_args_procedure);
end;
ensure
cpp.on_c
end;
feature {PROC_CALL_1}
used_for_c_inline(ms: MANIFEST_STRING) is
require
ms /= Void
local
mangling: STRING;
do
mangling := ms.mangling;
if mangling_dictionary.has(mangling) then
mangling_dictionary.remove(mangling);
end;
end;
feature {GC_HANDLER}
define_manifest_string_mark is
local
i, mdc, ms_count, function_count: INTEGER;
ms: MANIFEST_STRING;
do
mdc := mangling_dictionary.count;
function_count := 1;
define_manifest_string_mark_header(function_count);
from
i := 1;
until
i > mdc
loop
if ms_count > 300 then
ms_count := 0;
function_count := function_count + 1;
cpp.put_string(fz_manifest_string_mark);
cpp.put_integer(function_count);
cpp.put_string(fz_c_no_args_procedure);
cpp.put_string(fz_12);
define_manifest_string_mark_header(function_count);
end;
ms := mangling_dictionary.item(i);
cpp.put_string("((rsoh*)(");
cpp.put_string(ms.mangling);
cpp.put_string(
"->_storage)-1)->header.magic_flag=RSOH_MARKED;%N");
ms_count := ms_count + 1;
i := i + 1;
end;
cpp.put_string(fz_12);
end;
feature {JVM}
jvm_define_fields is
local
cp: like constant_pool;
ms: MANIFEST_STRING;
name_idx, string_idx, i, mdc: INTEGER;
do
mdc := mangling_dictionary.count;
if mdc > 0 then
cp := constant_pool;
string_idx := cp.idx_eiffel_string_descriptor;
from
i := 1;
until
i > mdc
loop
ms := mangling_dictionary.item(i);
name_idx := cp.idx_utf8(ms.mangling);
field_info.add(9,name_idx,string_idx);
i := i + 1;
end;
end;
end;
jvm_initialize_fields is
local
cp: like constant_pool;
ca: like code_attribute;
ms: MANIFEST_STRING;
i, mdc: INTEGER;
do
mdc := mangling_dictionary.count;
if mdc > 0 then
cp := constant_pool;
ca := code_attribute;
from
i := 1;
until
i > mdc
loop
ms := mangling_dictionary.item(i);
ca.opcode_push_manifest_string(ms.to_string);
ca.opcode_putstatic(ms.fieldref_idx,-1);
i := i + 1;
end;
end;
end;
feature {NONE}
mangling_dictionary: DICTIONARY[MANIFEST_STRING,STRING] is
once
!!Result.with_capacity(4096);
end;
body: STRING is
once
!!Result.make(2048);
end;
define_se_ms(string_at_run_time: BOOLEAN) is
do
header.copy("T7*se_ms(int c,char*e)");
body.copy("T7*s=");
gc_handler.new_manifest_string_in(body,string_at_run_time);
body.append(
"s->_count=c;%N%
%s->_capacity=c+1;%N%
%s->_storage=((T9)");
gc_handler.new_native9_in(body,string_at_run_time);
body.append(
"(c+1));%N%
%memcpy(s->_storage,e,c);%N%
%return s;");
cpp.put_c_function(header,body);
--
cpp.put_c_function("T7*se_string_from_external_copy(char*e)",
"/* Creation of an Eiffel STRING by copying C string e. */%N%
%return se_ms(strlen(e),e);");
end;
define_manifest_string_mark_header(number: INTEGER) is
do
header.copy(fz_void);
header.extend(' ');
header.append(fz_manifest_string_mark);
number.append_in(header);
header.append(fz_c_void_args);
cpp.put_c_heading(header);
end;
fz_manifest_string_mark: STRING is "manifest_string_mark";
header: STRING is "................................";
fz_se_msi: STRING is "se_msi";
nb_ms_per_function: INTEGER is 50;
end -- MANIFEST_STRING_POOL